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&lt;script type="text/javascript" language="javascript"&gt;

	/*
	 *
	 * Attach functions to an arbitrarily named object to mimic a namespace to ensure the name uniqueness
	 *
	 */
	var tyty = {};


	/*
	 *
	 * This function will return a prompt object
	 *
	 * Function Parameters:
	 *	promptName = the name of the prompt to be returned
	 *
	 */
	tyty.getControl  = function  (promptName) {
		var ocr= cognos.Report.getReport("_THIS_");
		return ocr.prompt.getControlByName(promptName);
	}

	/*
	 *
	 * This function validates the date values.
	 * We have to take into account that for ranges, getValues works the following way:
	 * When the range values are equal, getValues return a normal value instead of a range : [ {use: useValue, display:displayValue} ]
	 * When values are different then it returns a range:  [ start:{use: useValue, display:displayValue}, end:{use: useValue, display:displayValue} ]
	 * 
	 */	
	tyty.dateRangeValidator = function() {
		var oCR= cognos.Report.getReport("_THIS_");
		datePrompt=oCR.prompt.getControlByName("myDateRange");

		// This value determines how many days apart the date values can be.
		var rangeLimit = 10;

		// Only do something if the date value is not empty
		if (datePrompt) {
			// Create an array of date prompt values
			var aDatePromptValues = datePrompt.getValues();

			//Get the first value from the array
			var rangeValue = aDatePromptValues[0];

			//Initialize a variable to hold the number of days between the two dates
			var rangeDaysDiff = 0;

			// If the range start and end dates are set, then validate it
			if (rangeValue.start &amp;&amp; rangeValue.end) {
				// Get the start and end dates as strings
				var startDate = rangeValue.start.use;
				var endDate = rangeValue.end.use;

				// Convert string prompt values to proper dates
				var startDateObj = tyty.strDateToDateObj(startDate); 
				var endDateObj = tyty.strDateToDateObj(endDate); 

				// Calculate the difference in days between the dates
				rangeDaysDiff = dateUtils.substractDate(endDate,startDate);

				// The .getTime method, calculates the time in milliseconds between date and 01 January 1970.
				// Determine the difference between the dates in milliseconds
				var diffInMS = endDateObj.getTime() - startDateObj.getTime();

				// If (milliseconds time difference is not zero)
				// then result = (the difference in days) 
				// else 0.
				rangeDaysDiff =  Math.round(diffInMS != 0? diffInMS/dateUtils.dayInMilliSeconds : 0);
			} 

			if (rangeDaysDiff &gt;= 0 &amp;&amp; rangeDaysDiff &lt;= rangeLimit) {
				divDisplayError.innerHTML = "";
				returnValue = true;

			} else {
				divDisplayError.innerHTML = "The dates selected cannot be more than " + rangeLimit + " days apart. Please select a shorter date range." ;
				returnValue = false;
			}
		return returnValue;
		}
	}

	/*
	 *
	 * This function associates the validation function with the prompt control
	 *
	 */
	tyty.setRangeValidator = function() {
		var datePrompt = tyty.getControl("myDateRange");
		if (datePrompt) { 
			datePrompt.setValidator(tyty.dateRangeValidator); 
		}
	}
	  

	/*
	 *
	 * This function takes the prompt date value, breaks it apart and returns a JavaScript Date object
	 *
	 */
	tyty.strDateToDateObj = function(dateValue){
		var dateYear = dateValue.substr(0,4);
		var dateMonth=dateValue.substr(5,2);
		var dateDay=dateValue.substr(8,2);
		var result = new Date(dateYear, dateMonth-1, dateDay);
		return result;
		};

	/*
	 *
	 * These are date utility functions 
	 *
	 */
	dateUtils = {
		weekDays: ["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],
		dayInMilliSeconds: 24 * 3600 * 1000,
		wDaytoString: 
			function(wday /* int */) {
				return (wday&gt;-1 &amp;&amp; wday&lt;7? dateUtils.weekDays[wday]:null);
			},
		date2LabelWday:
			function(tDate) {
				return dateUtils.wDaytoString(tDate.getDay()) + " "  + tDate.getDate();
			},
		addDays2Date: 
			function(tDate, daysDiff) {
				var refDatetime = tDate.getTime();
				var tTime = refDatetime + (daysDiff * dateUtils.dayInMilliSeconds);
				return new Date(tTime);
			},
		substractDate:function(endDate, startDate) {
			var startDateObj = tyty.strDateToDateObj(startDate); 
			var endDateObj = tyty.strDateToDateObj(endDate); 
			var diffInMS = endDateObj.getTime() - startDateObj.getTime();
			return Math.round(diffInMS != 0? diffInMS/dateUtils.dayInMilliSeconds : 0);
		}
	};


	// Script execution starts here
	// Execute the function to associate the prompt and its validation function
	tyty.setRangeValidator();
&lt;/script&gt;
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